在使用echarts制作数据图表时,由于一张图表中包含多个series并且是多种类型数据(折线图,散点图,自定义图等),最初所有数据都是在各自的series.tooltip中定义提示信息,这种情况下默认tooltip的触发方式是‘item’的方式,但是折线图在这种方式下的使用就很蛋疼了,必须要点中数据点,提示才会出来,但是数据点又比较小,很难点中,用户反馈很不好用;
为了用户体验更好,只好改代码了,本来打算只对折线图采用坐标触发(‘axis’),但是series.tooltip无法设置触发方式,只好更改option.tooptip触发方式为‘axis’,;在这里又碰到了问题,修改后的触发方式作用在所有的series上了,也就是之前自定义的series.tooltip全都无效了,查echarts官方文档才发现:
series.tooltip 仅在 tooltip.trigger 为 ‘item’时有效。如意算盘落空了,没法子对不同类型的图采用不同的触发方式了;
没办法,因为折线图的体验效果实在太差,必须要改,只好硬着头皮改了,所有的数据都采用‘axias’触发,然后针对不同的图表给出不同的提示,方法就是:在series.tooltip中使用formatter函数来自定义提示信息,依据params参数的seriesIndex(数据在series里位置)属性来判断图表类型;代码实现如下:
1 | drawChart1_2() { |
auth.js中定义函数,对不同类型数据做处理:
1 | formatterTip(params){ |
这样就完成 了echarts坐标轴触发方式下的多个series的tooltip自定义功能;上述函数中只给出了一部分series的处理方法;
完成后效果还不错,可惜没法截图;